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NOTA IMPORTANTE: 

Algunos programas incluidos en los CD de 
“Programación y Diseño de Videojuegos” son 
versiones completas, pero en otros casos se 
trata de versiones demo o trial, versiones de 
evaluación que Iberprensa quiere ofrecer a 
nuestros lectores. No se trata en ningún caso de 
las versiones comerciales de los programas, y 
las hemos incluido para dar al lector la oportuni- 
dad de conocer y probar esos programas y que 
así pueda decidir posteriormente si desea o no 
adquirir las versiones comerciales de cada uno. 


Aprende divirtiéndote 


Bienvenidos a Programación y Diseño de Videojuegos, la primera 
obra coleccionable cuyo objetivo es formar al alumno en las principales 
técnicas relacionadas en el desarrollo completo de un videojuego. 


A lo largo de la obra el lector aprenderá programación a nivel general y 
a nivel específico con ciertas herramientas y lenguajes, aprenderá a tra- 
bajar con aplicaciones de retoque de imagen y también de diseño 3D y 
animación. Descubrirá las aplicaciones profesionales más importantes 
de audio y conocerá la historia de lo que se denomina “la industria del 
videojuego”, los últimos 20 años, los juegos que marcaron un avance, 
sus creadores y en general la evolución del videojuego. 


Pero además, esta obra tiene un segundo objetivo, desarrollar y poten- 
ciar la creatividad del lector, nosotros a lo largo de las diferentes entre- 
gas pondremos las bases y tú pondrás tu ingenio, tu creatividad y tu 
capacidad de mejorar. 


Comienza aquí un viaje de 20 semanas articulado en 400 páginas y 20 
CD-ROMs cuya finalidad es proporcionar las bases mínimas para des- 
pués cada uno continuar su camino. 


Recuerda que para alcanzar el éxito necesistas cumplir tres condicio- 
nes: que te gusten los juegos, poseer cierta dosis de creatividad y final- 
mente capacidad de estudio. 


Una la cumples seguro. 


201 Zona de desarrollo 
Empezamos a aprender a implementar al protagonista del juego, controlan- 
do su movimiento y el de la cámara. 


205 Zona de gráficos 
Continuamos fabricando los distintos elementos del juego; en esta oca- 
sión, creamos los restantes seres que habitan los terrenos de combate. 


209 Zona de audio 


Seguimos creando loops y viendo distintas herramientas que hacen de 
FruityLoops un potentísimo programa. 


211 Blitz 3D 


Después de realizar nuestros modelos, vamos a texturizarlos y a pintarlos 
con la ayuda de los brushes. 


215 Tutorial 


Empezamos una nueva serie de tutoriales relacionados con el desarrollo 
viendo el manejo de niveles BSP. 


217 Historia del videojuego 
Seguimos con los juegos de estrategia, conociendo la historia de los RTS o 
juegos de estrategia en tiempo real. 


219 Cuestionario 
Cada semana un pequeño test de autoevaluación, en el próximo número 
encontrarás las respuestas. 


Contenido CD-ROM 


Páginas dedicadas a la instalación y descripción 
del software que se adjunta con cada coleccionable. 


Su marlo 
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Para consultas, dudas técnicas y reclamaciones Iberprensa 
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la obra “Programación y Diseño de Videojuegos” se AAA 
pondrán a la venta las tapas 1 y 2. 3 
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» Los suscriptores recibirán las tapas en su domicilio 


reembolso del precio de venta al público más el coste de los 
gastos de envío. Pueden ser solicitados en el teléfono de atención 


sin cargo alguno como obsequio de Iberprensa. al cliente 91 628 02 03 


ontrolando al 
protagonista (|) 


n esta primera entre- 

ga acerca de cómo 

implementar a nues- 

tro protagonista en el 
juego, empezaremos por con- 
trolar su movimiento y el de la 
cámara, tratando también la 
actualización de su estado 
durante la partida. 


(u) MOVIENDO A 
NUESTRO 
PROTAGONISTA 

Antes de empezar, vamos a 

situar todo el procedimiento de 

control del jugador en la función 

“control_jugador_principal()” en 

el módulo “jugador_principal.bb”. 

La bionave de combate es 
movida por el jugador mediante el 
ratón y/o de las teclas del cursor. 

Debemos, sin embargo, estudiar 

previamente cómo se ha diseña- 

do este movimiento para saber 
qué instrucciones debemos utili- 
zar. Sabemos que la premisa más 
importante es que la bionave 
siempre está en movimiento. Por 
lo tanto, lo más sensato será utili- 
zar el comando “MoveEntity” 
para desplazarla. Otra cuestión es 
cómo la movemos. Básicamente, 
todo el control de la bionave se 
centra en el uso del ratón a través 
de su desplazamiento y la pulsa- 
ción de los botones, aunque 
podemos añadir el control por 
teclado fácilmente. Pero centré- 

monos en el uso del ratón. A 

pesar de que la obtención de 

datos a través de periféricos 
externos la estudiaremos más 
detenidamente en la sección 

“Blitz3D” de una próxima entre- 

ga, adelantaremos su uso en este 

número de una forma sencilla y 

fácil de comprender. 


(um) ROTANDO LA BIONAVE 
CON EL RATÓN 

Lo que primero nos interesa es 

cómo obtener el desplazamiento 
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del ratón y convertirlo en datos 
numéricos, los cuales servirán 
para modificar las coordenadas 
de la bionave. Solamente nos 
interesa el movimiento de los 
ejes horizontales del ratón para 
modificar la rotación de la nave 
en su eje Y. Así que, desplazán- 
dolo de izquierda a derecha, 
hacemos que la bionave gire para 
cambiar de rumbo ya que, si 
recordamos, siempre está en 
movimiento. 

Es importante resaltar que, 
para crear un punto de rotación 
central en la nave, es imprescindi- 
ble crear un pivote. El procedi- 
miento para su creación lo imple- 
mentamos en el momento de car- 
gar el fichero y crear el modelo en 
la función “crear_modelos()” del 
módulo “funcpantaudio.bb”: 

Function crear_modelos() 
bionave=LoadMesh (“c:Wzone of 
fightersimodelosYbionave.3ds”) 
pivote _bionave= 

CreatePivot (bionave) 


De vuelta al módulo de con- 
trol, comenzamos la función 
almacenando en la variable flo- 
tante YY ++ el desplazamiento 
horizontal absoluto del ratón 
mediante la función 
“MouseXSpeed”, la cual detec- 
ta los cambios en su movi- 
miento. El valor obtenido por 
esta función es un número 
entero; debemos convertirlo en 
un número flotante y dividirlo 
entre 7 para obtener valores 
decimales y así tener incre- 
mentos o decrementos de des- 
plazamientos razonables. 

my*H=my+t+Float (MouseXSpeed () ) /-7 
YY*=EntityYaw (bionave) +my 

A continuación, ejecutamos 

la rotación de la bionave y su 


sombra en su eje Y. Además, 
hemos tenido en cuenta un 
incremento extra en la veloci- 
dad de rotación cuando la 
cámara se encuentra en el 
modo subjetivo o primera per- 
sona, controlado por la variable 
global “tipo_camara”: 
RotateEntity bionave, 0, yy+ 
MouseXSpeed() , 0 
De esta forma, todo el proce- 
so queda como sigue: 
If tipo_camara=1 
myitt=mytHFloat (MouseXSpeed () ) /-7 
YYH=EntityYaw (bionave) +my 
RotateEntity bionave, 0, yy+ 
MouseXSpeed(),0 
RotateEntity sombra_bionave, 
0,yy,0 
Else 
mytt=nyiH+Float (MouseXSpeed () ) / 
-7 : my=my/2 ¡"+ Mitad de 
velocidad de giro para 32 
persona 
YY+=EntityYaw (bionave) +my 
RotateEntity bionave, 0,yy,0 
RotateEntity sombra_bionave, 
0,yy,0 
EndIf 
MoveMouse GraphicsWidth() 
Shr 1,GraphicsHeight () Shr 1 


myA=my4+Float(MouseXSpeed())/-7 
YY A=EntityYaw(hionave)+my 


Pivote_Bionav reatePivot (Bionave) 


Representación gráfica de la rutina de rotación y 
desplazamiento de la bionave. 
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La función “MoveMouse” 
colocará el cursor (invisible) 
siempre en el centro de la panta- 
lla, así nunca perderemos el des- 
plazamiento del ratón (Fig. 1). 


(mu) DESPLAZAMIENTO Y 

ACELERACIÓN 
En el diseño del juego contem- 
plamos la idea de que la bionave 
del protagonista se encuentra en 
continuo desplazamiento. El 
único control que el jugador 
puede tener sobre este desplaza- 
miento es aumentar o disminuir 
la aceleración. Para ello, elegimos 
de nuevo el ratón como vehículo 
principal de control. Utilizaremos 
entonces el botón derecho para 
aumentar la aceleración. Si lo 
pulsamos aumentará y si lo sol- 
tamos disminuirá hasta una velo- 
cidad inicial establecida. También 
debemos contemplar la posibili- 
dad del uso del teclado por parte 
del jugador, ya que siempre es 
necesario implementar en el 
juego todas las opciones posi- 
bles de control. Así que utilizare- 
mos la tecla del cursor “arriba” 
para aumentar también la acele- 
ración. 

Las variables que utilizaremos 
para dotar a la bionave de movi- 
miento son: velocidad* y acelera- 
ción**. Ambas son inicializadas 
en “Definiciones.bb” con los 
valores 0.8 y 0.2 respectivamen- 
te. 

Para implementar este control 
utilizamos una sentencia condi- 
cional: 

If (MouseDown (boton2) Or 
KeyDown(200)) Then 
velocidadtt=velocidad+aceleraciont 
MoveEntity bionave, 0,0, velocidad 
Else 
velocidad=velocidad- (aceleracion**2) 
MoveEntity bionave, 0, 0, velocidad 
EndIf 


Si pulsamos el botón derecho 
del ratón o pulsamos el cursor 
“arriba” incrementamos la veloci- 
dad según el valor contenido en 
aceleraciónK* (0.2). Si no, reduci- 
mos la velocidad el doble de rápi- 
do que aceleramos: 


De esta forma, evitamos una 
desaceleración brusca y conse- 
guimos un movimiento suave. 
Pulsemos el botón o no, siempre 
desplazamos la bionave en su eje 
Z; es decir, hacia delante o hacia 
atrás, ya que el resto de direccio- 
nes lo determinará el giro: 


MoveEntity bionave,0,0,velocidad 


Es necesario añadir una con- 
dición más a la anterior senten- 
cia. Se trata de controlar la velo- 
cidad máxima para que al acele- 
rar haya un tope. Utilizaremos 
otra variable llamada 
velocidad_max% la cual inicializa- 
mos con un valor de 15: 


If (MouseDown (boton2) Or 
KeyDown(200)) And velocidad < 
velocidad _ max Then 


De esta manera conseguimos 
que la velocidad actual de la bio- 
nave no supere el valor 15. 

A su vez, hemos de controlar 
también la velocidad mínima, por 
ejemplo 4; de esta manera garanti- 
zamos un desplazamiento mínimo 
continuo. Debemos añadir, segui- 
damente, una sentencia más: 


Antes de controlar el factor de 
gravedad, debemos actualizar las 
coordenadas de la bionave y la 
posición de la cámara llamando a 
la función “mueve_camara”": 

mueve_camara (bionave, 

velocidad seguimiento) 

Para el correcto funciona- 
miento de la función es impres- 
cindible pasarle como paráme- 
tros la entidad a la cual seguirá, 
en este caso la bionave, y a la 
velocidad que lo hará (“veloci- 
dad_seguimiento”) (Fig. 2). 


(1) CONTROLANDO 
LA CAMARA. 
FUNCIÓN 
“MUEVE CAMARA” 

El juego soporta cuatro vistas de 

cámara diferentes: subjetiva, ter- 

cera persona, cenital y segui- 
miento en tercera persona. En 


—_————> 


Velocidad _seguimiento $ 


La distancia entre la cámara y la bionave en 3* 
persona depende de la variable 
“Velocidad_seguimiento”. 


todos los casos existe una parti- 
cularidad común y es que la 
cámara sigue en todo momento 
a la bionave. Para realizar este 
procedimiento utilizaremos la 
instrucción “PointEntity”, la cual 
implementaremos en la función 
“mueve_camara” situada en el 
módulo “Fjuego.bb”. 

Los parámetros de entrada de 
esta función son: el objetivo a 
seguir (“objetivo”) y la velocidad 
de seguimiento de la cámara 
(“velocidad_camara”): 

Function mueve_camara 

(objetivo, velocidad camara) 

Posteriormente actualizamos la 
posición de la bionave almacenán- 
dola en las variables X4, YH y Z4: 


xHt=EntityX (bionave) 
yH=EntityY (bionave) 
zH+=EntityZ (bionave) 


Continuamos, calculando las 
coordenadas de la cámara con 


Fórmulas empleadas para calcular las coordena- 
das de la cámara con respecto al objetivo (bio- 
nave). Además, permiten desplazar y rotar la 
cámara de una forma suave. 


E 


PointEntity Camara , Objetivo 


DA 


Independientemente de la vista escogida, la 
cámara siempre apuntará al objetivo (bionave) 
mediante la instrucción “PointEntity”. 


respecto al objetivo a seguir. Para 
ello, determinaremos un despla- 
zamiento según la posición 
actual de la cámara y del objetivo 
y lo almacenaremos en las varia- 
bles CX4% y CZH4: 


CcxH=EntityX (camara) 

czH=EntityZ (camara) 

objetivo_xtt=EntityX (objetivo) 

objetivo_ztt=EntityZ (objetivo) 

Objetivo_x%* y objetivo_z 4% 
almacenarán la posición del obje- 
tivo a seguir, en este caso la bio- 
nave, que servirán luego para 
actualizar la posición de la cáma- 
ra de una forma suave y siempre 
dependiendo del contenido de la 
variable velocidad_camara. Para 
implementar estos desplazamien- 
tos utilizaremos las fórmulas que 
se muestran en la figura 3. 


cxtt=cxit+ ( (objetivo_xHt-cxit) 
/velocidad_camara) 
czH=czHH+ ( (objetivo_zHt-czt) 
/velocidad_camara) 


La altura de la cámara depen- 
derá del tipo de vista que se 
haya seleccionado. De tal modo 
que, si la vista es subjetiva -en 
primera persona-, debemos 
situarla al nivel de la cabeza del 
protagonista. Para ello, situare- 
mos la cámara 4 puntos más 
arriba del centro vertical de la 
bionave; es decir, “YH + 4”. Para 
el resto de las vistas, precisare- 
mos en todo momento de la 
altura del terreno. Además, es 
necesario añadirle una altura 
extra para evitar una visión a ras 
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de suelo y de esta manera situar 
la cámara por encima de la bio- 
nave. Debemos entonces utilizar 
una variable para almacenar esta 
altura adicional: 

distancia Y_camara%. 

Este valor será el que determi- 
nará los tipos de vista cenital, 
tercera persona o seguimiento. 
Por defecto asignamos un valor 
de 158 en el módulo de 
“Definiciones.bb”. 
Almacenaremos este valor en la 
variable CY que será la que utili- 
cemos finalmente: 


cytt=distanciaY camara 
If tipo camara=1 ; Primera persona 
PositionEntity camara, cx, y+4,CZ 
Else ; Otras vistas 
PositionEntity Camara, cx, 
TerrainY (terrenol,EntityX 
(bionave) , EntityY (bionave) , 
EntityZ (bionave) ) +cy, cz 
EndIf 
Finalmente, nos queda apun- 
tar la cámara hacia el objetivo y 
actualizar la variable y_bionavetf, 
la cual nos ayudará a situar la 
sombra de la bionave, ya que 
almacena la posición de ésta 
sobre el terreno: 
PointEntity camara,objetivo 
y bionave=TerrainY (terrenol, 
X,y+20,Z) 


(um) CAMBIANDO LAS 
VISTAS DE CÁMARA. 
FUNCIÓN 
“CAMBIAR_CAMARA” 

Dentro del módulo “Fjuego.bb”, 

hemos situado, a continuación 

de la anterior función, un proce- 
dimiento para actualizar la situa- 
ción de la cámara en las distintas 
vistas disponibles para el usua- 
rio. La función adquiere el pará- 
metro del tipo de cámara elegido 
almacenado en la variable global 
tipo_camara: 


Después, simplemente utiliza- 
mos una sentencia “Select .. 
Case” para modificar los paráme- 
tros de la situación de la cámara 
según el tipo elegido. 


(m) DESARROLLO 


Hay otros factores a tener en 


cuenta a la hora de cambiar las 
vistas y son controlar la visuali- 
zación de la bionave, su sombra 
y cambiar el zoom de la cámara. 
Por lo tanto, en la vista subjetiva 
debemos ocultar la entidad bio- 
nave y su sombra para poder dar 
la sensación deseada. Para ocul- 
tar la bionave cambiaremos su 
Opacidad a O con “EntityAlpha 
bionave, O ” y para hacer lo 
mismo:con la sombra utilizare- 
mos ” HideEntity sombra_biona- 
e ”. Es necesario controlar tam- 
bién si el jugador tiene activado o 
no el camuflaje, examinando la 
variable camuflaje_bionave: 


Select tipo_camara 


Case 1 
distanciaZ_camara=-2 
velocidad _seguimiento=6 
EntityAlpha bionave, 0 
HideEntity sombra_bionave 
CameraZoom camara, .54 

Case 0 
distanciaY_camara=107 
distanciaZ_camara=0 
velocidad _seguimiento=15 
If camuflaje _bionave=0 

EntityAlpha bionave, 1 
Else 

EntityAlpha bionave, .1 
EndIf 

ShowEntity sombra_bionave 

CameraZoom camara, .8 

Case 2 
distanciaY camara=700 
distanciaZ_camara=0 
velocidad seguimiento=63 
If camuflaje _bionave=0 

EntityAlpha bionave, 1 
Else 
EntityAlpha bionave, .1 


Dos ejemplos de la vista en tercera persona. 
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(1) DESARROLLO 


Algunos ejemplos de vista de seguimiento en 
tercera persona. 


EndIf 
ShowEntity sombra_bionave 
CameraZoom camara, .8 
Case 3 
distanciaY_camara=62 
distanciaZ_camara=-139 
velocidad _seguimiento=12 
If camuflaje _bionave=0 
EntityAlpha bionave, 1 
Else 
EntityAlpha bionave, .1 
EndIf 
ShowEntity sombra_bionave 
CameraZoom camara, .54 
End Select 
Para terminar la función es 
preciso devolver el valor de la 
variable tipo_camara: 


(um) CONTROLANDO EL 
FACTOR GRAVEDAD 

Para determinar un entorno creíble 

es importante proporcionar ciertos 

elementos físicos, como por ejem- 

plo la gravedad. Implementarla es 


Gravedad 


MoveEntity Bionave, 0, - Gravedad, 0 


Esquema gráfico del funcionamiento del control 
de la gravedad. 
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realmente fácil. Sólo tenemos que 
mover a la bionave continuamente 
hacia el suelo decrementando su 
coordenada Y con el valor de 
“gravedad”, pero sólo si está 
sobre el suelo; es decir, si supera 
el valor “Y=0": 


Tf y _bionave>0 
MoveEntity bionave, 0, -gravedad, 0 


De todas formas, el sistema 
de colisiones tiene prioridad fren- 
te al sistema de coordenadas. 
Por lo tanto, aunque siguiéramos 
decrementando la coordenada Y, 
la bionave se pararía al tocar con 
el terreno. La sentencia condicio- 
nal anterior sólo nos sirve para 
evitar, precisamente, que la coor- 
denada “y_bionave” baje del 
valor O (Fig. 7). 

Explicaremos la implementa- 
ción de las colisiones con el 
entorno en una próxima entrega. 


(um) AÑADIENDO DETALLES. 
SOMBRA Y 
COMBUSTIÓN 

Para terminar, podemos añadir 

otros detalles, como la sombra 

de la bionave o la combustión del 
motor. 

El hecho de añadir una som- 
bra a la nave no se debe sólo a 
cuestiones estéticas, ya que la 
bionave se desplaza sobre el 
terreno en suspensión. Por lo 
tanto, es fundamental imple- 
mentarla para proporcionar 
información adicional al jugador 
de la altura de la bionave. 
Utilizando, pues, la variable 
y_bionave, obtenemos la altura 
actual de ésta sobre el terreno. 
De este modo, sólo tenemos que 
colocar la sombra según los ejes 
X, Y y Z de la bionave y 15 pun- 
tos más abajo con referencia al 
eje Y (Fig. 8). 

Si “y_bionave” vale 
“TerrainY (terreno1,x,y+20,z)”, 
debemos posicionar la sombra 
en “y_bionave+b": 

PositionEntity sombra_bionave, 

Xx, y bionave+5,z 

Otro factor a tener en cuenta 
es proporcionar el efecto de la 


A diferencia de la figura inferior, en la superior 
se puede apreciar la distancia de la bionave al 
suelo gracias al uso de sombras. 


combustión del motor. Este 
hecho reforzaría aún más la idea 
de que la bionave está continua- 
mente en movimiento. La mejor 
manera de implementar la com- 
bustión es a través de un emisor 
de partículas situada en el tubo 
de escape. Pero de este elemen- 
to hablaremos con mucho más 
detalle en una próxima entrega 
(Fig. 9). 

Hay muchos más aspectos 
que pueden ser implementados 
en las rutinas de movimiento y 
cámara del protagonista como 
pueden ser la aplicación de 
algún tipo de animación o colo- 
car una nueva cámara que 
muestre la parte trasera de la 
bionave. 


Un ejemplo de emisión de partículas para simu- 
lar la combustión del motor. 


En el próximo 
número... 


»»| 


... Continuaremos contro- 
lando a nuestra bionave, 
programando las acciones 
de disparo, camuflaje y 
activación del escudo. 


a NÚMERO 
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Fabricando los 


elementos del juego (II) 


n este número termi- 
naremos de realizar 
el Luny. Continuare- 
mos fabricando el 
resto de seres que habitan 
los terrenos de combate 
como los “Shaark” y las 
plantas carnívoras 
“Dreecks”. 


Para crear el mapeado UV rea- 
lizaremos la misma operación 
que con el “Slunk” en 
LithUnWrap. Optimizaremos y 
aplicaremos un “UV mapping” 
“Planar” con la opción “Y 
top”. Una vez salvado, lo car- 
gamos con Deep Paint 3D 
para texturizarlo. Generamos 
un material nuevo con 256 x 
256 de tamaño y aplicamos 
una imagen en blanco 
“Nothing” al canal de color 
(*C”). Ajustamos el modelo en 
la ventana y aplicamos un 
relleno con la textura Skin 2 
en Texture Paints. Para finali- 
zar, pintaremos los detalles de 
la sangre y suciedad en la 
base de la planta utilizando la 
misma variación de pincel que 
en el modelo anterior; es 
decir, Paste Oil + en Variations 
con un pincel escalado al 15% 
(Fig.1). 

Una vez pintado, exporta- 
mos la textura con el nombre 
“textura_luny.bmp” en el 
directorio “C.duego_ZOFWMWunyA 
texturizado”. 


Esta planta tiene un aspecto 
parecido al de las mazas utili- 
zadas como armas en la Edad 


Media. No tiene movimiento 
alguno y aparecerá en el 
juego clavada en la tierra. Así 
que empezamos modelando 
el tronco que no es más que 
un cilindro de 2 “Stack” 
(Divisiones) y 8 “Slices”. Para 
crear la base de la esfera de 
la planta, desplazamos los 
vértices que dividen las dos 
secciones del tronco hacia 
arriba. Seleccionamos los 
vértices superiores y, con la 
herramienta de escalado, los 
abrimos. A continuación, de 
los 8 vértices bajamos 4 de 
dos en dos y salteados como 
se muestra en la figura 2 
para lograr una forma estre- 
lada. 

Para crear la cabeza de la 
planta elegimos una geoesfera 
de densidad 1 y la situamos 
sobre la base en forma de 
estrella que acabamos de 
modelar. Para formar los pin- 
chos que irán clavados en la 
cabeza de la planta partimos 
de cilindros de una sola divi- 
sión y de 3 “Slices”. 
Seleccionamos los vértices 
superiores y los unimos con 
“Ctrl” + “N” para formar la 
punta. Una vez modelada la 
espina la colocamos en cual- 
quier lugar de la cabeza. Ya 
sólo nos queda duplicarla 
varias veces y repartir las nue- 
vas espinas por la superficie 
de la esfera realizando opera- 
ciones de rotación y desplaza- 
miento. Finalizamos, seleccio- 


Después de cubrir con una textura el modelo es 
interesante la aplicación de detalle por medio del 
pincel. 


Procedimientos para el modelado de una planta 
Shaark. 


Procedimientos para el texturizado de un 
Shaark. 


Los anillos de un cilindro nos servirán para dar 
forma al tallo de la planta. 


La mitad de una geoesfera es ideal para obtener la 
base de la boca. 


Para obtener la forma de las hojas a partir de tres 
cubos unidos podemos aplicar las herramientas de 
escalado y rotación en las uniones. 


nando todas las piezas y 
agrupándolas para exportar 
como un sólo mesh y en for- 
mato .ms3D con el nombre 
“shaark.ms3d” en el directorio 
“Cujuego_ZOFRishaarkimodela- 
doy” 


El mapeado UV lo crearemos 
de nuevo con LithUnWrap, 
pero en esta ocasión, y una 
vez optimizado, aplicaremos 
un “UV Mapping” “Planar” en 
su eje X, para conseguir una 
plantilla que muestre una 
disección del modelo. 

Exportamos en formato 
.OBJ y posteriormente lo car- 
gamos en Deep Paint 3D para 
texturizarlo. 

Al igual que en el modelo 
anterior, generamos una 
nueva textura de dimensiones 
256 x 256 y aplicamos 
“Nothing” en el canal “C 
Vamos a pintar con aspecto 
diferente el tronco y la cabeza 
de la planta. Para empezar, 
ajustamos el modelo a la vista 
y seleccionamos toda la cabe- 
za y los pinchos con la herra- 
mienta de selección rectangu- 
lar Rectangle tools. Elegimos 
la textura Skin 1 en Texture 
Paint de Command Panel y 
aplicamos la herramienta de 
relleno. Seguimos con el tron- 
co. Una vez seleccionado le 
aplicamos un relleno con la 
textura Skin 3+, la cual hemos 
modificado previamente el 
tono (“Hue”) a 61 y el tamaño 
horizontal (“Scale X”) a 13.25. 
Como siempre, aplicaremos 
algunos detalles para darle a 
la planta un aspecto más real. 
Empezamos por perfilar la 
base de la planta con el pincel 
y eligiendo un color verdoso y 
el efecto de pintado Pastel Oil 
+ en Variations. Luego pintare- 
mos manchas de sangre en 
las espinas y cuerpo y algo de 
suciedad en el tronco con el 
pincel al 15 % de su tamaño y 
con la característica Pastel 


.” 


Oil. No olvidemos elegir el 
color rojo para la sangre y un 
tono marrón para las manchas 
de suciedad (Fig. 3). 

Una vez hayamos termina- 
do, exportamos la textura 
contenida en el canal de color 
con el nombre “textura_sha- 
ark.bmp” en el directorio 
“Cujuego_ZORMtexturizadoN 
shaark”. 


Para modelar la planta tene- 
mos que definir una postura: 
optamos por hacerla total- 
mente rígida, mirando hacia 
arriba y con los tentáculos de 
los ojos extendidos. La sensa- 
ción de movimiento se cons- 
truirá posteriormente con el 
esqueleto en Character FX. 
Empezamos por la base de 
la planta, la cual parte de una 
esfera con 6 “Stacks” y 12 
“Slices”. Seleccionamos la 
mitad de la misma sin elegir 
Ignore Backfaces y cortamos. 
Seguidamente, el vértice 
superior de la mitad de la 
esfera lo desplazamos hacia 
abajo para crear el hueco 
donde irá el tallo (Fig. 4 — 1). 
Para crear el tallo partimos 
de un cilindro de 4 divisiones 
de altura (stack) y 8 de circun- 
ferencia (slices) Estas divisio- 
nes o anillos nos servirán 
posteriormente para dar algu- 
na forma al tallo (Fig. 4 - 2 ). 
Ensanchemos, pues, la base 
del tallo seleccionando (F1) 
los vértices más inferiores 
con la herramienta de escala- 
do (F4) en la vista superior. 
Hacemos la misma operación 
con los vértices de las divisio- 
nes impares siguientes desde 
abajo hacia arriba. Para la últi- 
ma división superior realiza- 
mos un escalado mayor que 
en las demás hacia fuera, ya 
que servirá como apoyo a la 
siguiente pieza que es la base 
de la boca (Fig. 4 - 3). Para 
esta pieza, utilizamos una 
geoesfera de densidad 1 y le 


borramos la mitad superior de 
los vértices. A continuación, 
ajustamos la esfera a la parte 
superior del tallo, la cual habí- 
amos ensanchado. El ajuste lo 
realizamos mediante operacio- 
nes de escalado y desplaza- 
miento (Fig. 5 - 1). 

Para modelar las hojas 
vamos a utilizar tres cubos 
aplastados, alargados y uni- 
dos entre sí. Sólo es necesa- 
rio modelar uno de ellos con 
la herramienta de escalado. 
Los demás los iremos dupli- 
cando (“Ctrl” + “D”) y colo- 
cando uno a continuación del 
otro para poderlos unir (Fig. 5 
- 2,3). La unión la realizamos 
seleccionando el primer vérti- 
ce superior de cada cubo 
ignorando los de atrás 
(Ignore Backfaces deseleccio- 
nado) y pulsando “Ctrl” + “D” 
(Snap Together). Hacemos lo 
mismo con los vértices infe- 
riores. A continuación, elegi- 
mos los vértices traseros con 
Ignore BackFaces selecciona- 
do y los pegamos también. El 
resto de los cubos los uni- 
mos de la misma manera 
(Fig. 6 — 1). 

Para dar la forma a las 
hojas a partir de los tres 
cubos unidos, utilizaremos las 
herramientas de escalado y 
desplazamiento en los vérti- 
ces que hemos unido. Por 
ejemplo, para obtener la punta 
de la hoja, seleccionaremos 
los vértices más exteriores en 


la vista superior y los escala- 
mos hacia dentro (Fig. 6 - 2). 
Para obtener las formas cur- 
vas, elegiremos los vértices 
del centro, también en la vista 
superior, y los desplazaremos 


¡Video 


hacia un lado. Estos procedi- 
mientos se muestran gráfica- 
mente en la figura 7. 

Para la otra hoja sólo tene- 
mos que duplicar la que tene- 
mos, seleccionándola comple- 
tamente y pulsando “Ctrl” + 
“D”. Seguidamente, hacemos 
un Mirror Front <-> Back en el 
menú Vertex Para evitar que 
sea igual que la primera, la 
modificaremos un poco 
mediante el desplazamiento 
de sus vértices y la colocare- 
mos un poco más abajo en el 
tallo. 

La boca del Dreeck está 
compuesta por dos grandes 
mandíbulas. Para modelarla, 
necesitaremos una esfera de 
6 “Stacks” y 12 “Slices” divi- 
da en dos. Para ello, tenemos 
que seleccionar la mitad de 
los vértices con Ignore 
Backfaces deseleccionado y 
borrarlos. Nos quedamos 
entonces con la mitad de la 
esfera que corresponderá a 
una de las mandíbulas. Sólo 
es necesario trabajar con una 
de ellas, ya que la otra la 
podemos obtener mediante 
un duplicado (Fig. 8 - 1,2). 

Hay que tener en cuenta 
que, al cortar una esfera, la 
parte interior queda vacía; es 
decir, no hay ninguna cara 
poligonal y necesitamos 
cerrarla. Si cambiamos la vista 
de perspectiva en modo “Flat 
Shade” podemos observar 
este hecho (Fig. 8 - 3). Para 
cubrir el hueco dejado, nece- 
sitamos fabricar manualmente 
los polígonos que faltan. 
Partiremos, para realizar esta 
operación, de los vértices que 
forman el contorno interior de 
la semiesfera. Los selecciona- 
mos y los desplazamos hacia 
un:lado para poder unirlos. 
Para ello, elegimos la herra- 
mienta Face del grupo Model 
y unimos cada vértice entre sí 
de tres en tres para formar los 
polígonos que cerrarán la 
semiesfera (Fig. 9). 

Una vez completada la ope- 
ración, volvemos a colocar la 
cara interior de la semiesfera 
en su sitio seleccionando de 


Mediante el desplazamiento individual de vértices 
podemos dar variadas formas a las primitivas. 


La mitad de una esfera puede servir perfectamen- 
te como mandíbula. 


Una vez cortada la esfera es necesario cubrir de 
polígonos el hueco interior para obtener adecua- 
damente una de las mandíbúlas. 


Una vez cerrada la semiesfera, la duplicamos para 
crear la otra mandíbula. 


A partir de un cilindro y por medio de los procedi- 
mientos utilizados para crear las hojas es posible 
obtener los tentáculos oculares. 


Antes de texturizar la planta es necesario crear el 
mapeado UV, en este caso con LithUnwrap. 


nuevo todos los vértices y 
desplazándolos a su lugar ori- 
ginal (Fig. 10). 

El siguiente paso será ajus- 
tar la mandíbula a la base de 
la boca con las herramientas 
de escalado y desplazamiento. 
Una vez ajustada, duplicamos 
y hacemos un espejo horizon- 
tal (Mirror Front<->Back) para 
generar y colocar la otra man- 
díbula (Fig. 10 -3). 

Las últimas partes que nos 
quedan son los tentáculos 
que albergarán a los globos 
oculares. Partimos de un cilinm- 
dro con 3 partes que coloca- 
remos horizontalmente en la 
vista “Left” rotándolo 90 gra- 
dos. Para dar forma al cilindro 
y obtener un aspecto más 
orgánico, seleccionamos los 
vértices de cada parte del 
cilindro y los desplazamos al 
igual que hicimos con el 
modelado de las hojas. 
Debemos también preparar el 
extremo del tentáculo para 
albergar el globo ocular. Así 
que, mediante el desplaza- 
miento de los tres vértices 
abrimos el extremo del cilim- 
dro como se muestra en la 
figura 11. 

Para el otro tentáculo, reali- 
zamos de nuevo un duplicado 
y una simetría horizontal y 
ajustamos la nueva posición. 

Para los globos oculares 
utilizamos una esfera de 4 
“Stacks” y 4 “Slices”. Para 
terminar: le asignamos un 
tamaño adecuado, la coloca- 
mos en el extremo del tentá- 
culo, duplicamos y aplicamos 
de nuevo una simetría hori- 
zontal. 


B RECORDATORIO 


Finalmente, debemos 
agrupar todas las partes, 
seleccionando el modelo 
completo y pulsando el 
botón “Regroup” en la herra- 
mienta de agrupamiento 
Groups (Fig.11 - 3,4). 

Ya sólo nos queda salvar el 
modelo terminado en formato 
.OBJ para poder texturizarlo 
con Deep Paint 3D. 


Antes de crear la textura de la 
planta es preciso general su 
mapeado UV. Aunque es posi- 
ble hacerlo con Deep Paint 3D 
a través de la herramienta 
“MercatoruvV”, utilizaremos 
LithUnwrap, ya que nos per- 
mitirá también aplicar un opti- 
mizado de vértices. 

Como es habitual, dentro 
de LithUnwrap, cargamos el 
modelo y elegimos la opción 
Optimize Model en el menú 
Tools. Una vez realizada la 
optimización, seleccionamos 
el objeto por completo con 
Select / All y de nuevo en el 
menú Tools elegimos UV 
Mapping / Decal y pinchamos 
la opción Positive / x- right 
para alinear los ejes hacia un 
lado. 

Finalmente, exportamos el 
modelo en formato .OBJ y ya 
estamos preparados para tex- 
turizar nuestra planta carnívo- 
ra (Fig. 12). 


B RECORDATORIO 


En el próximo 
número... 
. realizaremos el texturi- 
zado y la animación del 
Dreeck. 


Herramientas para hacer 


la música de un juego (11) 


n el número anterior 
comenzamos a desa- 
rrollar un loop en 
Fruity Loops. 
Estudiamos lo fácil que es 
crear y copiar patrones, los 
cuales utilizaremos para 
componer la canción que 
servirá de loop. En esta 
entrega terminaremos nues- 
tro loop y seguiremos cono- 
ciendo nuevas característi- 
cas que hacen de esta herra- 
mienta una de las más sofis- 
ticadas e interesantes. 


En Fruity Loops, la canción se es- 
cribe en la sección “Playlist”. En 
ella, se crea una serie de listas 
con el orden de reproducción de 
cada patrón a lo largo de una lí- 
nea de tiempo. Para visualizar 
“PlayList” elegimos la opción 
“View / Playlist” o bien “Ctrl” + 
“1”. Es preciso activar el modo 
“Loop” para poder trabajar en 
“Playlist”. Una vez activado, la 
reproducción (“Play”) sólo afec- 
tará a “Playlist”-y no a las pistas 
de patrones. “Playlist” está divi- 
dido por una cuadrícula. Cada 
cuadro corresponde a un com- 
pás. Horizontalmente lo forman 
los diferentes compases a lo lar- 
go del tiempo y verticalmente los 
diferentes patrones. De este mo- 
do, para construir la canción sólo 
tenemos que rellenar estos cua- 
dros dibujando con el ratón. 
Podemos ver en la figura 1 la 
composición en “Playlist” para 
nuestro loop (este loop esta con- 
tenido en el CD con el nombre 
“loop _fruity.wav”) (Fig. 1). 

Una vez terminado el loop, só- 
lo queda exportarlo en formato 
WAV (aunque también es posi- 
ble hacerlo en .MP3) Elegimos la 
opción File / Export / Wave File ... 
o pulsamos “Ctrl” + “R”. 


, Video 


Aparecerá una ventana flotante, 
donde podremos elegir la calidad 
para nuestro loop. 


La posibilidad que Fruity Loop 
admite para la edición de las pis- 
tas es sorprendente y con un di- 
seño eficaz. Antes de continuar, 
apuntar que en Fruity Loops las 
pistas de sonido se denominan 
canales. Disponemos de un edi- 
tor gráfico que nos permite mo- 
dificar los parámetros del volu- 
men, panorámico, tono, frecuen- 
cia de corte, etc.. de cada canal. 
Con sólo pulsar sobre el botón 

aparecerá debajo del canal 
seleccionado un panel donde, 
mediante un lápiz, podemos di- 
bujar los nuevos parámetros pul- 
sando el botón izquierdo del ra- 
tón. Para borrarlos, utilizaremos 
el botón derecho. En la parte in- 
ferior del panel se encuentra un 
deslizador, que sirve para elegir 
los diferentes parámetros. 

Para seleccionar otro canal, 
basta con pulsar en el “led” o lu- 
cecita verde que hay en el co- 
mienzo de los compases y para 
mutarla o desactivarla en la luz 
que se encuentra debajo de los 
botones de volumen y panorá- 
mico. 

También disponemos de un 
editor gráfico de notas, el cual 
aparecerá debajo del canal selec- 
cionado al pulsar el botón 
Este panel tiene forma de peque- 
ños teclados en el que podemos 
seleccionar el tono de nuestra 
nota (Ver Fig. 2). 


Fruity Loops trabaja con dos ti- 
pos diferentes de canales según 
su contenido: canales de mues- 
tras (“sampler”) y canales de so- 
nidos sintetizados (“TS404”) El 


En la sección “Playlist” es donde escribimos la 
canción que servirá de loop. 


Pa 


Editor gráfico de notas y procedimiento para 
insertar un nuevo canal. 


Descripción de los principales parámetros del edi- 
tor de muestras. 


Descripción de los principales parámetros del sin- 
tetizador TS404. 


Procedimientos para la asignación y edición de 
efectos. 


comportamiento es el mismo pa- 
ra los dos, la diferencia estriba en 
el tipo de sonido que reproducen. 
Los canales de muestras pueden 
reproducir ficheros de sonidos en 
formato .WAV, .Xl (Fast Tracker), 
DS, (DrumSynth) y .SYN 
(SimSynth) y los canales TS404 
reproducen sonidos creados con 
el sintetizador de bajos TS404. 
Para insertar un nuevo canal 
elegimos la opción Channel / 
Add one y el tipo de canal 
(“Sampler”o “TS404”). También 
podemos hacerlo en el menú flo- 
tante que aparece al pulsar con el 
botón derecho del ratón sobre el 
botón que muestra el sonido en 
cada pista (5. En el mismo me- 
nú, también es posible realizar 
Operaciones de clonado y borra- 
do de canales, así como funcio- 
nes de edición básicas. 
yn >) ' L 
Al pulsar sobre el botón 21 se 
abrirá una nueva ventana llamada 
“Channel settings” en donde po- 
demos modificar todos los pará- 
metros del sonido. 


S 


En la ventana “Channel set- 
tings”, la pestaña “SMP” corres- 
ponde a los parámetros de una 
muestra. Desde ahí podemos 
cargarla, crear una nueva, modifi- 
carla o grabar la nueva muestra 
modificada. En la figura 3 se des- 
cribe este panel. 

Pulsando sobre la gráfica de la 
muestra la reproducimos y hacien- 
do clic con el botón derecho del 
ratón, mostramos las opciones 
para cargarla, crearla o grabarla. 

Para modificar su sonoridad 
tenemos varios parámetros. En 
primer lugar, disponemos de tres 
filtros (“FX1”, “Sine FX” y “FX 
3”), los cuales se utilizan para 
cambios de volumen y modula- 
ción de la onda. Además, dispo- 
nemos de un amplificador 
(“Amp”), reverberación 
(“Reverb”), frecuencia de corte 
(“Cut”). También es posible mo? 
dificar el ataque (“Att”); es decir, 
acentuación del comienzo y el 
decaimiento o fade (“Dec”). En 
“Reverse” cambiamos el orden 


de la muestra y las luces rojas 
“A" y “B” conmutan entre el ca- 
nal izquierdo y el derecho del es- 
téreo. 


Si el canal seleccionado contiene 
un sonido TS404 la ventana 
Channel settings adquiere otro 
aspecto. En ella, se muestran to- 
dos los parámetros propios de 
un sintetizador (pestaña TS404). 

Básicamente se trata de un 
sistema de síntesis para líneas 
de bajos. Consta de dos oscila- 
dores (OSC1 y OSC2), que son 
mezclados en el apartado “OSC 
1+2”. También podemos modifi- 
car la envolvente del sonido me- 
diante los parámetros “Att” 
(Attack), “Dec” (Decay), “Sus” 
(Sustain) y “Rel” (Release). 

Disponemos, además, de 4 
filtros (LP12, LP24, BP y HP) en 
el apartado “Filter” y de un osci- 
lador (LFO) para hacer oscilar el 
tamaño del primer oscilador o los 
filtros. Y por último, podemos 
aplicar a toda la onda distorsión 
(Dist) y eco (Delay). 

A través de la pestaña 
“PITCH” podemos modificar el 
tono de la onda con valores ab- 
solutos (“Middle note”) o relati- 
vos (“Fine”) (Ver Fig. 4). 


Para ambos tipos de canales es 
posible la aplicación de múltiples 
efectos. Éstos se eligen y asig- 
nan en la ventana Song settings, 
la cual se abre al pulsar con el 
botón derecho del ratón sobre 
las luces “FX1” hasta “FX8” de la 
ventana Channel settings. Es po- 
sible mezclar hasta 4 efectos a la 
vez para un canal de efectos. Los 
elegimos pulsando sobre la pe- 
queña flecha invertida junto a 
“(none)” en “Select” o 
“Favorites” y lo activamos o de- 
sactivamos pulsando en el pe- 
queño “enchufe” de la derecha 
E. Una vez elegido el efecto, 
aparecerá una nueva ventana 
que muestra todos los paráme- 
tros de dicho efecto (Ver Fig. 5). 
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a creación de un 
modelo 3D empieza 
con su modelado y 
termina definiendo su 
aspecto final mediante la 
aplicación de texturas. 

Como recordaremos, una 
textura es una imagen 2D, 
diseñada con una aplicación 
de dibujo que cubre un objeto 
3D, dándole a éste su aparien- 
cia definitiva. Blitz3D permite 
crear texturas, cargarlas de 
disco o modificarlas. En este 
número aprenderemos todo lo 
necesario para texturizar 
nuestros modelos y pintarlos 
con el uso de brushes. 


Y CREANDO 
TEXTURAS 

Se pueden crear texturas 

manualmente desde progra- 

mación o bien a través de una 

imagen. 


0 FICHEROS DE IMÁGENES 
COMO TEXTURAS 

Este primer método es el más 

sencillo y consiste en crear la 


El mejor formato para utili- 
zar texturas en Blitz3D es 
.PNG. Ocupa poco espacio 


en disco al igual que .JPG, 
comprime con calidad 

parecida a .BMP y admite 
canal alfa (transparencia). 


El formato .JPG no soporta 
canal alfa, mientras que 
.PNG y .TGA sí. Si utiliza- 
mos un formato sin canal 
alfa, Blitz3D lo emulará 
creando uno propio por 
medio de valores de coior. 


Funciones 3D (11). Texturizado 
1 de objetos 3 


D y brushes 


textura a partir de un 
fichero de imagen (.BMP, 
¿PNG, .JPG, ¿PCX, O 
.TVGA) Se utiliza la fun- 


COLOR (por defecto) 


CANAL ALFA (Colores alfa serán transparentes 


MASCARA (Las áreas con color no se dibujaran) 


ción: 


MIPMAPPED (Textura con bajo detalle y suavizado 
a grandes distancia) 


( 5: UNIR COORD. TEXT. HORIZONTAL (U) (Evita el 
enrrolamiento de la textura) 


UNIR COORD. TEXT. VERTICAL (V) (Evita el 
enrrolamiento de la textura) 


El parámetro “flags” 
Oo banderas permite la 
aplicación de efectos a 
la textura una vez carga- 
da. Estos efectos se 
pueden combinar 
sumando banderas. En 
la figura 1 se muestra un 
esquema con las diferentes 
banderas y su efecto asocia- 
do. En el ejemplo: 


MAPEADO DE REFLEXION ESFERICA (Mapeado de 
entorno) 


Lista de los parámetros “flags” posibles para la carga de 
texturas. 


con “LoadAnimTexture”, B3D 
separa la secuencia en foto- 
gramas independientes y asig- 
na la animación como textura. 


El consumo de memoria al 
cargar texturas no depende 
del formato utilizado. Si car- 
gamos texturas en .JPG no 
significa que ocuparán 
menos memoria por estar 
comprimidas. Ocuparán lo 
mismo que si están en for- 
mato .BMP. La explicación 
de esto es que Blitz3D utili- 
za su propio formato; es 
decir, cuando se carga una 
imagen para convertirla en 
textura, independientemen- 
te del formato, Blitz3D con- 
vierte esa imagen en una 
textura con su propio for- 
mato interno. 

La única diferencia que 
encontramos en el uso de 
diferentes formatos está en 
el tiempo de carga. Por 
ejemplo, una textura en for- 
mato .BMP tardará más 
tiempo en cargarse que la 
misma en .JPG ya que, al no 
estar comprimida, el fichero 
es mayor. 


La variable “Textura” mani- 
pulará la textura creada a par- 
tir de la imagen “mi_textura” 
que se ha cargado con color 
(bandera 1) y canal alfa (ban- 
dera 2) (1+2=3). 


0 TEXTURAS ANIMADAS A 

PARTIR DE IMÁGENES 
Un claro ejemplo de cómo 
B3D transforma las imágenes 
contenidas en ficheros a tex- 
turas lo encontramos en la 
función “LoadAnimTexture”. 
Este comando permite la crea- 
ción de texturas animadas por 
medio del encadenamiento de 
imágenes (frames) contenidas 
en un fichero (Ver Fig. 2 y 
“ejemplo1.bb”). 

Para crear este tipo de tex- 
tura es necesario tener en un 
mismo fichero, y de forma 
consecutiva, las diferentes 
imágenes que forman la 
secuencia de la animación. 
Una vez cargada la imagen 


1 


de ZLmMa 


Esquema de cómo construir una textura animada con un 


programa de dibujo. 


Al igual que en la función 
“LoadTExture”, es posible apli- 
car los mismo efectos por 
medio de “Flags”. Es importan- 
te definir el tamaño que tendrá 
cada fotograma exactamente 
igual a como lo hayamos dibu- 
jado; es decir, si la secuencia 
de imágenes la forman cua- 
dros de 64 x 64 debemos 
colocar en “Tamaño horizon- 
tal” y “Tamaño vertical” un 64. 
El “primer fotograma” corres- 
ponderá al O. Si en el “Número 
de fotogramas totales” pone- 
mos un valor inferior al núme- 
ro de imágenes contenidas en 
la secuencia del fichero, B3D 
rellenará los huecos con blan- 
co. Por ejemplo, disponemos 
de un fichero en donde hemos 


Captura sobre un ejemplo de aplicación de texturas 


animadas. 
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dibujado una 
secuencia de imá- 
genes para la tex- 
tura del agua. Este 
fichero contiene 10 
fotogramas (0-9) 
de tamaño 64 x 64: 


Es importante 
tener en cuenta 
que en el ejemplo 
anterior la imagen del fichero 
original debe tener un tamaño 
total de 640 X 64 (10 Cuadros 
de 64 = 640 x 64 de altura). Si 
no fuera así, ocurriría un error. 


$ CREANDO TEXTURAS 
MANUALMENTE DESDE 
PROGRAMACIÓN 
Otra posibilidad muy flexible e 
interesante que permite B3D 
es la creación de texturas a 
partir de cero y dibujarlas a 
través del buffer de texturas 
“TextureBuffer”. 


Para crear una textura 
nueva utilizamos la función 
“CreateTexture”: 


Las opciones de 
efectos aplicados 
según “flags” son 
las mismas que en 
las funciones ante- 
riores (ver Fig. 1) 

y la opción 
“Fotogramas” indi- 
ca el número de 
fotogramas que 
tendrá la textura 

si así fuese. 

Por defecto su 
valor es 1. 

Podemos crear 
el tamaño de tex- 
turas que quera- 


Textura aplicada a un cubo, la cual ha sido previamente 
dibujada desde programación en el búfer de texturas. 


mos. El único límite lo impone 
la tarjeta gráfica. De todas for- 
mas, si la tarjeta no soportara 
el tamaño que hayamos espe- 
cificado, B3D asignará auto- 
máticamente el más cercano 
disponible. También, normal- 
mente se usan texturas cua- 
dradas con tamaños múltiplos 
de dos iguales; es decir, 256 
x256, 64 x64. Aunque es lo 
más normal -ya que lo sopor- 
tan todas las tarjetas-, es 
posible asignar tamaños dife- 
rentes como 256 x 128 o 512 
x 64, siempre y cuando los 
valores sean múltiplos de 2. 
Para dibujar graficos 2D en 
la textura primero debemos 
activar el búfer de textura: 
SetBuffer TextureBuffer 
Seguidamente, dibujaremos la 
imagen y, por último, la copia- 
mos al búfer de texturas. Se 
puede ver el funcionamiento 
de este proceso en los ejem- 
plos “ejemplo2.bb”, “ejem- 
plo3.bb” y “ejemplo4.bb”. 


Ejemplo del proceso de dibujar en el búfer de textura en 
tiempo real. 


Diseño y 
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Es posible escalar las texturas en cualquier dirección. 


Si lo que deseamos es 
dibujar gráficos 3D, no pode- 
mos hacerlo directamente en 
el búfer de texturas. Tenemos 
primero que dibujar en el 
“BackBuffer” y luego con la 
instrucción “CopyRect” 
copiarlos al “TextureBuffer”. 


SS) MANIPULANDO 

TEXTURAS 
Disponemos de multitud de 
comandos para el manejo de 
texturas, desde escalarlas 
hasta cambiar sus coordena- 
das en el modelo. 

Para cambiar el tamaño de 
una textura utilizaremos la 
instrucción “ScaleTexture”: 


(Horizontal), 
(Vertical) 


(Ver “ejemplo5.bb”). 

Para rotar una textura apli- 
cada a un modelo utilizaremos 
“RotateTexture”: 


Rotat xture 


(Ver “ejemplo6.bb”). 
Esta instrucción es de 


Una vez aplicada la textura 
al modelo podemos borrarla 
de la memoria con el 
comando “FreeTexture 
Textura”. Una vez borrada 
no podrá ser usada de 
nuevo; sin embargo, el 
modelo seguirá texturizado. 


Diseño y 5 
Programación de 


acción inmediata y 
resulta muy útil 
para aplicar efec- 
tos a los modelos. 
Suele ser muy utili- 
zada en sistemas 
de partículas. 


9 SCROLL DE 
TEXTURAS 
Hay un último 
comando que nos 
permite realizar 
desplazamientos 
de la textura apli- 


Ejemplo de rotación de texturas sobre meshes. 


cada a un objeto 
3D, muy útil para realizar 
scroll de texturas y simular 
movimiento (Ver 
“ejemplo7.bb”). Por ejemplo, 
está muy extendido su uso en 
texturas utilizadas para simu- 
lar la superficie del agua. En el 
“ejemplo8.bb” se muestra la 
aplicación de este sistema 
para simular un río de lava. 


(9 MEZCLANDO TEXTURAS: 
“BLENDING” 
La técnica “blending” estable- 
ce la forma en que la textura se 
mezclará con el objeto u otra 
textura (en caso de multitextu- 
rizado). Es posible mezclar 
hasta 8 texturas según la tarje- 
ta gráfica. La textura número O 
se mezclará con los polígonos 
del objeto aplicado, la textura 1 
con la textura O y así sucesiva- 
mente. 
En B3D es posible aplicar esta 
técnica mediante la instrucción 
“TextureBlend”: (Ver “ejem- 
plo9.bb”) 


El parámetro “Modo 
de mezcla” determina el 
modo “blending” que 
B3D aplicará: 

Hi Valor O: no se aplica- 
rá ninguna textura. 

E Valor 1: no se realiza 
mezcla alguna o sólo 
el canal alfa si lo 
hubiera. 

E Valor 2: se multiplica 
la mezcla. Es el valor 
por defecto. 


E Valor 3: se suma la mezcla; 
es decir, en multitexturiza- 
do, se suma una textura 
con otra. 


Y CREACIÓN DE 

BRUSHES 
Un brush o pincel es un grupo 
de propiedades (color, brillo, 
textura, etc.) que pueden ser 
aplicadas a una entidad, 
superficie o mesh. Los brus- 
hes se utilizan, por ejemplo, 
para cambiar el aspecto de 
algunos polígonos del mode- 
lo, ya que, con funciones de 
entidad como “EntityColor”, 
cambiaremos el color el obje- 
to completo. 

Para asignar o pintar 
con un brush a un mesh 
utilizamos PaintMesh Mesh, 
Brush. 

Para hacer lo propio con 
una entidad: PaintEntity 
Entidad, Brush y para pintar 
una superficie: PaintSurface 
Surface, Brush. 


NA A a O NA aa 


Un ejemplo práctico sobre la técnica de scroll de texturas 
para simular el fluir de un río de lava. 
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cada brush por lo 
que se pueden 
obtener muchos 
más efectos. 


Y CREANDO 
BRUSHES A 
PARTIR DE 
FICHEROS DE 
IMÁGENES 

Con la instrucción 

“LoadBrush” 

podemos cargar 

Ejemplos de la técnica “blending” (mezcla) aplicada a un fichero de ima- Mediante la aplicación de efectos a un brush se pueden 

texturas. gen, crear una obtener resultados muy interesantes. 

textura con él y 

asignarla poste- 


Y CREANDO BRUSHES riormente a un brush: Los modos de mezcla son: 
MANUALMENTE el 1 canal alfa, 2 multiplicar y 

Para crear un brush desde g z 3 sumar. 

cero utilizaremos la instruc- ( Hay una instrucción muy 

ción “CreateBrush”: ] interesante que es 

“BrushAlpha”, y se puede uti- 
Nuevo _Brush= CreateBrush Las opciones “Flags” son lizar para ocultar una entidad 
CI las mismas que las de las tex- en el lugar de “HideEntity”, en 
13) turas (ver Fig. 1). el caso de que se quiera 

O Además, podemos definir seguir detectando por el siste- 
Podemos crear un brush directamente el escalado que ma de colisiones. 

nuevo y posteriormente asig- tendrá la textura aplicada al Por último, disponemos de 

narle una textura con el brush. otro comando para la aplica- 

comando “BrushTexture”: ción de efectos extras: 


Y APLICANDO  . 
EFECTOS A LOS 


BRUSHES 
Al igual que ocurre con las Los parámetros de efectos 
texturas, es posible aplicar pueden ser sumados para 
ciertos efectos a los brushes combinar efectos. 
como brillo, color, etc. Los valores posibles para 
Para asignar un color a un “Efecto” son: 
brush utilizaremos: Ml O: Por defecto (ningún 


efecto). 
1 ] E 1: Brillo. 
Es posible asignar hasta 4 ME 2: Usar “Vertex Colors” en 
capas (0-3) de texturas por A A A] vez de “Brush Color”. 
Se puede obtener un M4: Sombreado plano. 
brillo más intenso en Ml 3: El efecto de niebla no 
ciertas partes del afectará al modelo. 
modelo donde la luz Ml 9: Desactiva la ocultación 
incide por medio del de los polígonos traseros. 
comando: Se muestran todos los polí- 


gonos en modo 
“Wireframe” (alámbrico) 
(Ver “ejemplo10.bb”). 


También es posible 


: "” E 
utilizar “blending” en los [SS] En el próximo 
número... 


10 EE- 18 brushes con: 
. . estudiaremos el sistema 
Mediante el “blending” se pueden mezclar texturas de de animación y las técni- 
diversas maneras. cas más recomendadas. 
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ómo manejar 
niveles 


mpezamos una serie 

de tutoriales relacio- 

nados con el desarro- 

llo y programación de 
juegos. Dedicaremos este 
espacio para construir ruti- 
nas útiles. 

Además, responderemos a 
cuestiones que quedaron pen- 
dientes durante el curso y 
ampliaremos otras que, por su 
interés, merecen un estudio 
más a fondo. Para empezar, 
estudiaremos una característi- 
ca muy interesante contenida 
en Blitz3D: el manejo de niveles 
BSP. 


7 MUNDOS BSP 

La nueva posibilidad que 
Blitz3D, a partir de su versión 
V. 1.76, brinda para el uso de 
niveles BSP, posibilita la crea- 
ción de una manera sencilla de 
juegos al estilo Quake. Antes 
de seguir, recordemos qué sig- 
nifica BSP y en qué consiste 
esta técnica: 

BSP son las siglas de 
“Binary Space Partitioning 
Tree” - árbol binario para la par- 
tición de espacio- y es, básica- 
mente, una forma de organizar 
objetos dentro de un espacio. 
Esta técnica aplicada a un 
entorno 3D coloca los objetos 
en una estructura de árbol que 
es seguida por el programa de 
forma ordenada y decide qué 
polígono se debe mostrar y 
cuál no. Es un buen método 
para eliminar del campo de 
visión áreas ocultas, con lo que 


Las cualidades del manejo 
de niveles BSP se encuen- 
tran disponibles a partir 
de la versión 1.76 de 


Blitz3D. 


se aumenta en gran medida el 

rendimiento total. 

Esencialmente, todo el tra- 
bajo que representa el manejo 
de árboles BSP lo resuelve 
Blitz3D para el usuario median- 
te su filosofía de entidades. 
Esto quiere decir que se puede 
cargar un nivel BSP completo y 
asignarlo a una variable como 
si de un modelo 3D se tratara. 
Así que, al ser una entidad, se 
le pueden aplicar los comandos 
básicos de éstas como posicio- 
namiento, escalado o rotación, 
así como todas las funciones 
completas de colisión. 

LoadBSP ( “Nivel.bsp” 

[, ajuste gamma] [,madre]) 

La opción “ajuste gamma” 
nos permite modificar la inten- 
sidad de luz del mapeado de 
luces del nivel BSP. El valor por 
defecto es O y va desde O 
hasta 1. 

Ahora bien, hay ciertos pun- 
tos que debemos tener presen- 
tes a la hora de utilizar modelos 
BSP: 

EM 1. Los modelos BSP no pue- 
den ser texturizados, pinta- 
dos, coloreados, etc... desde 
programación. 

M 2. Las texturas utilizadas en 
un nivel BSP deben ir en el 
mismo directorio que el 
modelo. 

M 3. Los modelos BSP no son 
iluminados por las luces 
ambientales del Blitz3D. Así 
que debemos utilizar la ilumi- 
nación propia para el modelo 
BSP (“BSPAmbientLight”). 

Ml 4. Si aplicamos “AmbientLight” 
normal del Blitz3D, éste se 
sumará al “AmbientLight” del 
nivel BSP, de tal manera que 
podemos jugar con estos dos 
valores para obtener algún tipo 
de efecto de iluminación. 


IWVIHO.LM.L 


Se muestra la activación de “LightMapping”. Y 
en la imagen inferior “Vertex Lighting”. 


BSPAmbienLight variable que 
contiene el modelo BSP, Valor 
de Rojo, Valor de Verdett, Azulk+ 
Ml 5. Es posible definir qué sis- 
tema de iluminación afectará 
al mundo BSP entre mapeado 
de luces (LightMapping) o ilu- 
minación de vértices (Vertex 
Lighting). Este último suele 
ser más rápido en algunas 
tarjetas gráficas pero no ofre- 
ce la misma calidad que un 
mapeado de luces. 
BSPLighting variable que 
contiene el modelo BSP, tipo 
de iluminación (True/False) 


Una zona sin iluminar (imagen superior) y la 
misma iluminada con el uso de la linterna (ima- 
gen inferior). Sistema “LightMapping” activado. 
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Una zona sin iluminar (superior) y la misma ilu- 
minada con el uso de la linterna (inferior). 
Sistema “Vertex Lighting” activado. 


Si en el parámetro “Tipo de 
iluminación” colocamos 
“True” se utilizará el mapeado 
de luces; si por el contrario 
utilizamos “False” elegiremos 
la iluminación de vértices 
(Fig. 1) 

Ejemplo: 


LoadBSP 
BSPAmbientLight 
BSPLighting 


7 UN EJEMPLO 
PRÁCTICO 


INTRODUCCIÓN 
Incluimos en el CD un ejemplo 
de cómo manejar niveles BSP 
llamado “BSP.bb y BSP.exe”. 
En él utilizamos colisiones, ilu- 
minación y cómo implementar 
un sistema de puertas automá- 
ticas. A continuación, haremos 
una descripción del programa 


Imágenes de las puertas automáticas imple- 
mentadas en el nivel BSP. 
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para esclarecer el uso de nive- 
les BSP. 

El ejemplo adjunto admite la 
posibilidad de navegar por el 
interior de un nivel BSP 
mediante una cámara y el uso 
del ratón y los cursores. 
También es posible activar o 
desactivar una linterna para 
estudiar las posibilidades de 
iluminación en tiempo real, así 
como la elección de los dos 
modos de iluminación posi- 
bles: “LightMapping” y “Vertex 
Lighting”. Además, se incluye 
un sistema que utiliza una 
estructura de datos para colo- 
car puertas en diferentes luga- 
res del nivel, las cuales se 
abren y cierran automática- 
mente al ser tocadas. 


DESCRIPCIÓN BREVE 

DEL PROGRAMA 
Después de definir las cons- 
tantes para el sistema de coli- 
siones y las variables necesa- 
rias, creamos la cámara que 
utilizaremos como entidad 
principal (Ver 
comentario”“Define camara”). 

Para crear la linterna, utiliza- 
mos una luz de tipo “Spot” con 
un cono de luz de 60 grados y 
dependiente de la cámara: 
Linterna=CreateLight(3,camara): 
LightConeAngles Linterna,O,60 

(Ver Fig. 2 y 3). 

Creamos una puerta a partir 
de un cubo escalado. Esta enti- 
dad nos servirá luego para 
hacer las copias de las demás 
puertas. Seguidamente, defini- 
mos una matriz (contendrá las 
posiciones y el estado de cada 
puerta) y su estructura corres- 
pondiente (Ver “Define puer- 
tas”). Después de cargar y defi- 
nir el nivel BSP, creamos el 
mapa de colisiones y llamamos 
a la función para crear las puer- 
tas Crear_Puertas(). En esta 
función, simplemente, añadi- 
mos una nueva puerta a la 
estructura y rellenamos los 
campos a partir de la matriz de 
datos (Ver “Función Crear 
Puertas”) (Ver Fig. 4). 

Dentro del bucle principal 
destacamos el procedimiento 
para detectar y guardar qué 


Al chocar con las puertas, éstas se abren hacia 
arriba y al segundo se vuelven a cerrar. 


puerta hemos tocado (Ver 
“Detecta puertas”). A conti- 
nuación, abrimos o cerramos 
las puertas dependiendo de la 
orden contenida en las varia- 
bles SW_Abrir y SW _Cerrar. 
Apuntamos que la variable 
auxiliar Aux_Puerta contiene la 
entidad puerta que hemos 
tocado y que pasaremos luego 
a las funciones de apertura y 
cierre (Ver Fig. 5). 

Para terminar, el resto de 
instrucciones se refiere a la 
activación de la linterna y de los 
diferentes modos de ilumina- 
ción y de todo el control por el 
usuario de la cámara (Fig. 6). 


Arriba, modo en alambre (wireframe) con 
“LightMapping” y abajo el mismo modo pero 
con “Vertex Lighting”. 


En el próximo 
número... 

... explicaremos la manera 
de implementar los dife- 
rentes sistemas de crea- 


ción de cielos para nues- 
tros entornos. 


A NÚMERO 


Iniaoajuegos || 


Juegos de estrategia (11). 
Estrategia en tiempo real 


ontinuamos con los jue- 

gos de estrategia, cono- 

ciendo la historia de un 

género que domina prác- 
ticamente la producción de juegos 
en la actualidad: los RTS o juegos 
de estrategia en tiempo real. 

La producción de títulos de 
este género es enorme y se cuen- 
ta por cientos. Debido a esto, só- 
lo mencionaremos los más signi- 
ficativos. También debemos ha- 
cer una distinción dentro de este 
género según la premisa básica 
del objetivo del juego; es decir, si 
tiene o no un carácter bélico. 


2UN PASO DE 
GIGANTE 
Volvamos atrás unos años y co- 
nozcamos la chispa que generó la 
masiva incursión de las partidas 
en tiempo real para un tipo de 
juego exclusivo de unos pocos 
donde las técnicas de tablero aún 
dominaban al PC. Allá en los co- 
mienzos de los 90, a un señor lla- 
mado Brett Sperry, obsesionado 
por buscar la diversión en los jue- 
gos de estrategia por turnos de 
aquel momento, se le ocurrió la 
brillante idea de que las posibili- 
dades del ordenador permitirían 
eliminar el sistema por turnos y 
hacer viable un género más atrac- 
tivo, fácil y sobre todo más entre- 
tenido. Nació entonces Dune ll en 
1992, de la mano de su desarro- 
lladora WestWood Studios, el pri- 
mer juego de estrategia en tiem- 
po real de la historia. A partir de 
ahí, WestWood creció meteórica- 
mente y publicó su siguiente tra- 
bajo, Command €: Conquer. Le 
siguió una saga completa basada 
en el mundo de C €: C, la cual se 
convertiría en la más vendida de 
la historia de los juegos de estra- 
tegia y construyó las bases del 
género: C £ C: Red Alert l y Il 
(1997 y 2000), Cé«C: Tiberina Sun 
(2000) (Dunell ,Cé8«C). 


NUMERO! Diseño y 
juegos 


Al igual que ocurrió en el gé- 
nero por turnos, apareció parale- 
lamente al ambiente bélico de 
Cé£C, un título ambientado en los 
mundos de Warhammer, 
Warcraft (Blizzard, 1994), en el 
que combaten orcos contra hu- 
manos. Le siguió Warcraft Il 
(Blizzard, 1996), que ha llegado a 
convertirse en un clásico. 


%5 EVOLUCIÓN 

TECNICA 
Empezamos como base dando 
un repaso a los títulos que usan 
una ambientación de conflictos 
armados para establecer el argu- 
mento del juego. 

La aparición de la estrategia 
en tiempo real originó la base 
fundamental de este genero, la 
Inteligencia Artificial (IA). Hasta la 
llegada del 3D, la única evolución 
que sufrían estos juegos hacía 
referencia sólo el apartado de la 
lA. De una forma u otra la base 
impuesta por WestWood para 
sus juegos era copiada hasta la 
saciedad, y prácticamente la in- 
terfaz de usuario o la jugabilidad 
eran iguales en todos los títulos: 
War Wind (SSI, 1996), KKND 
(Melbourne House, 1997), Earth 
2140 (Topware, 1997), Dark 
Reign (Activision, 1997), etc. 
Aunque también aparecieron jue- 
gos originales con otro tipo de 
ambientación como: Settlers ll 
(Blue Byte, 1996) y sus peque- 
ños colonos; la mezcla de rol y 
estrategia de Lords of Magic 
(Sierra, 1997); los robots de Z 
(BitMap Brothers, 1996) y 
Sindícate Wars (BullFrog, 1996) 
y, cómo no, Sid Meier's 
GettysBurg (Firaxis, 1997), basa- 
do en la Guerra Civil 
Norteamericana, etc. Pero en ge- 
neral, quizás la única diferencia 
radicaba en los gráficos y en la 
ambientación. Desde Dune ll 
hasta 1997 el género no cambió 


VIHO.LSIH 


a, MARLRAFE 
Dune ll y Warcraft fueron los primeros juegos de 
estrategia en tiempo real de la historia. 


La serie Command €: Conquer estableció las bases 
del género. 


Z y Gettysbug fueron dos ejemplos de títulos que 
se distinguían por su origina] ambientación en una 
época de producción masiva. 


217 


EMPIRES” 


E 


o 


ISA 
A MI 


m1 


mucho. Fue entonces cuando 
apareció Starcraft (Blizzard, 
1997), considerado uno de los 
mejores juegos de estrategia de 
todos los tiempos. En este mis- 
mo año irrumpe también 
Microsoft con Age of Empires 
que ganó el podium de los jue- 
gos de estrategias históricos. Así 
mismo, en este año tan prolífico 
apareció un nuevo concepto de 
jugabilidad con el título Total 
Annihilation (CaveDog, 1997). 


Una vez más, la evolución técnica 
en los compatibles llama a la 
puerta de las desarrolladoras de 
este género ofreciendo las nuevas 
tarjetas gráficas y señalando ha- 
cia el 3D. La perspectiva isométri- 
ca deja paso a la tercera dimen- 
sión y fue Bungie con su juego 
Mit.: The Fallen Lords los prime- 
ros en adoptarla en Noviembre de 
1997. Un nuevo mundo se abre 
ante la posibilidad de visualizar los 
combates desde diferentes pun- 
tos de vista y de poder ver con 
más detalles todas las unidades. 
Esto provoca una nueva revolu- 
ción comercial que hace que 7 de 
cada 10 juegos sean de estrate- 
gia. Obviamente, aparecieron nue- 
vos conceptos y sobre todo mejo- 
ras gráficas que abarcaban todos 
los argumentos imaginables. Sin 
embargo, los clásicos se mantie- 
nen y aparecen nuevas partes y 
expansiones adaptadas al 3D co- 
mo: la tercera parte de Age of 
Empires, Age of Mithology 
(Microsoft, 2001), Warcraft 3 
(Blizzard, 2001), Dark Reign 2 
(Activision, 2000) o Emperor: 
Battle for Dune (2001), primera in- 
cursión de WestWood en las 3D. 

Sin embargo, la isometría se- 
guía siendo la preferida de algu- 
nas desarrolladoras y sobre todo 
de los incondicionales del género 
y aparecieron títulos realmente 
brillantes como Tzar (Infinite 
Loop, 2000), Seven Kingdoms 
(Interactive Magic, 1998), o 
Space Clash (Dinamic 
Multimedia, 1999). 

A partir de 1999, la mayoría 
de los títulos se desarrollaban en 
3D y la potencia de las máquinas 
hacían cada vez más viable el 
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manejo de enormes cantidades 
de unidades y sobre todo un ma- 
yor espectáculo gráfico. Títulos 
como Shogun: Total War 
(Creative Assembly / Electronic 
Arts, 2000) pueden mostrar in- 
cluso hasta diez mil unidades a la 
vez en pantalla luchando entre sí 
o Warrior Kings (Sierra, 2001) en 
donde es posible admirar las ba- 
tallas a pie de soldado. 

Aparecen también títulos que 
mezclan la estrategia con el más 
puro arcade dando un nuevo 
concepto al género y proporcio- 
nando una jugabilidad fresca y 
asequible. Destacamos Sacrifice 
(InterPlay, 2000) desarrollado 
por los siempre originales chicos 
de Shiny Entertaiment o Giants: 
Citizen Kabuto (Planet Moon/ 
Interplay, 2000). 

Entra en juego la ambientación 
espacial y futurista para muchos 
títulos, encabezado por el fantás- 
tico Homeworld (Sierra, 1999), 
primera incursión de la estrategia 
espacial en las tres dimensiones 
con unos resultados increíbles ya 
que es posible controlar las bata- 
llas desde cualquier ángulo posi- 
ble. Un año después, Sierra publi- 
ca Ground Control, basado en el 
éxito de Homeworld, pero esta 
vez en tierra firme. Siguiendo los 
pasos de Sierra, se publican nue- 
vos títulos ambientados en el fu- 
turo y sobre todo en el espacio 
como son: Far Gate (Super X 
Studios, 2001), Conquest: 
Frontiers Mars (Ubi Soft, 2001), 
Star Wars: Force Commander 
(Lucas Arts, 2000), Star Trek: 
Klingon Academy (14 Degrees 
East/Interplay, 2000), etc. 

Muchos son los conceptos 
diferentes en torno a la estrategia 
en tiempo real que aún nos que- 
dan por ver. Subgéneros como 
los RPS (Role Player Strategy), la 
construcción de ciudades o la 
exclusiva gestión de recursos en 
todos los ámbitos conocidos, 
quedan pendientes. 
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Preguntas 


¿Cómo podemos dibujar con Blitz3D una textura en un objeto 3D en tiempo real? 

¿Qué son los brushes y cómo podemos crearlos en Blitz3D? 

¿Cómo podemos conseguir que nuestra nave espacial acelere al pulsar la tecla del 
espacio y desacelere al soltarla? 

¿Qué instrucción utilizaremos para que, por ejemplo, la cámara apunte siempre hacia un 
objeto? 


¿Cómo podemos darle la vuelta a los vértices de un polígono creado en Milkshape3D? 


¿Cuántos tipos de canales utiliza Fruity Loops y cuáles son? 


. ¿Cómo podemos cambiar la tonalidad de una textura en Deep Paint 3D? 
. ¿Cómo podemos añadir un efecto a una pista en Fruity Loops? 


¿Cómo podemos modificar la intensidad de luz de un nivel BSP en Blitz3D? 


1 
2 
3 
4 
5 
6 
7 
8 
9 
10. Define una luz en Blitz3D para utilizarla como linterna en un nivel BSP. 


Respuestas al cuestionario 10 


[> 1. En primer lugar creamos un mesh y luego una superficie: 
nuevo_mesh=Createmesh() 
Superficie=CreateSurface(nuevo_mesh) 
Seguidamente sumamos vértices y los unimos: 
AddVertex Superficie,-1,1,0 
AddVertex Superficie, 1,1,0 
AddVertex Superficie, 1,-1,0 
AddVertex Superficie,-1,-1,0 
AdaTriangle Superficie,0,1,2 
AddTriangle Superficie,0,2,3 
Para finalizar, actualizamos las normales: 
UpdateNormal nuevo_mesh 


> 2. Cargando el modelo con LoadAnimMesh, preguntar por la parte “cabeza” (suponiendo que se nombró como “cabeza” en el 
modelador) y texturizarla: 
Modelo= LoadAnimMesh(*modelo.3ds”) 
For n = 1 to CountChildren (Modelo) 
Cabeza = FindChild (Modelo, “cabeza") 
Next 
TextureEntity Cabeza, Textura_cabeza 


> 3. Con la función “CreateTimer” y “WaitTimer”: 
Timer = CreateTimer(60) ;60 FPS 


While Not Keydown(1) 
WaitTimer (Timer) 
RenderWorld 

Wend 


> 4. En 2D, los ejes X e Y corresponden a los ejes X y Z en 3D. 


[> 5. En primer lugar seleccionamos todo con la opción Select all en el menú Select y a continuación elegimos el tipa de mapeado UV 
con la opción UV Mapping en el menú Tools. 


> 6. Pulsando con el botón derecho sobre la capa “C” (color) situada en el menú de materiales. 


> 7. En primer lugar, hay que crear patrones en el modo Pattern. Seguidamente los pasamos al modo Song donde asignaremos la 
longitud del loop y lo crearemos a partir de los patrones. Para finalizar exportamos la canción (loop) a disco. 


> 8. En primer lugar, debemos crear patrones a través de los distintos canales. Una vez creados, pasamos a la sección Playlist en 
donde definimos la duración de los patrones en la canción. Una vez construida la canción ya hemos creado el loop. 


> 9. Por medio de puntos de inflexión colocados en la pista. Estos puntos se unirán formando una gráfica, la cual cambia la 
envolvente en toda la pista. 


> 10. Por medio de la opción Mix Down to File en el menú Edit del multipista. 
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Contenido 


» AUDIO 

El Intelliscore MID! Converter 5.0 
Convierte en MIDI cualquier fichero de audio 
en MP3 o WAV. 

MH Super MP3 Recorder 3.0.1 
Grabación de sonido desde micrófono para 
luego aplicarle efectos. 

El Crystal Audio Engine 0.1b 
Procesa señales digitales en tiempo real 
usando este programa multicanal. 

E Quartet X2 Music Studio 2.0 
Crea tus propias melodías con este potente 
y completo editor. 

Ml Sequbeat 

Programa de secuenciación para percusión 
con calidad de estudio de grabación. 

El Hammerhead Rythm Station 1.0 
Crea interesantes loops para tus composi- 
ciones. 
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»> DISEÑO 2D 
Ml Focus Magic 
Aplica fácil- 
mente efectos 
a tus imáge- 
nes con los 
filtros conte- 
nidos en este 
programa. 

E Collage Maker 

Crea tus propios collages con esta excelente 
herramienta en pocos minutos. 

E Snaglt 6 

Captura fácilmente imágenes o vídeo con 
un solo click usando esta sencilla 
aplicación. 

E VaryView 1.1 

Visualizador de imágenes, para que organi- 
ces todos tus archivos gráficos. 

H Graphics Converter Pro 4.0 
Práctica utilidad para editar rápidamente tus 
imágenes y cambiarles el formato. 
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E PhotoMark 1.0 
Protege tus imágenes para que nadie las 
use indebidamente y sin tu autorización. 


» DISEÑO 3D 

E 3D Exploration 1.81 
Herramienta muy completa para integrar y 
publicar gráficos en 2D y 3D fácilmente. 

E 2D €: 3D Animator 1.4 

Crea, anima y edita imágenes de calidad 
tanto en dos como en tres dimensiones. 

H Symmetrica 3D 3.0 

Poderoso programa para editar y renderizar 
3D. 

E ViZup Optimizer 1.1 
Herramienta de optimización 3D, para darle 
el máximo rendimiento a tus imágenes. 


MH Meshbox 1.0 

Maneja y convierte fácilmente tus conteni- 
dos en 3D. 

El Vue d'Esprit 4.1 

Crea, renderiza y anima escenarios natura- 
les ultra-realistas en tres dimensiones. 


» PROGRAMACIÓN 

Ml Map Master 2.0 

Toma todo el control de tus mundos virtua- 
les gracias a esta aplicación. 

E LAN-in-a-Box 1.0.3 

Con esta sencilla herramienta podrás crear 
partidas en red para cualquier juego en 
equipo. 

Ml HexDiff 3.0 

Utilisima 
herramienta 
con la que = 
podrás contro- | 
lar las versio- | 
nes del código, 
ya que se 
encarga de buscar diferencias entre éstas. 
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Ml File Substring Replacement 
Utility 7.0 

Otra utilidad; ésta se encarga de buscar y 

reemplazar strings en múltiples ficheros. 

Hl Elegant InterFace 4.0 

Personaliza tu espacio de trabajo con ele- 

gancia e imágenes usando este programa. 


» JUEGOS 
E Homeworld 
Primera incur- 
sión de la 
estrategia 
espacial en las 
tres dimensio- 
nes con unos 
resultados 
increíbles, 

Ml Age of Empires 

Estupendo juego que ganó el podium de los 
juegos de estrategias históricos, 

E Command €: Conquer 

Otro de los juegos de estrategia más vendi- 
dos de todos los tiempos. 

El Zone of Fighters 

Como cada semana, nuestro juego. 


» VÍDEO 

E DivX Pro Video 5.0.2 

Con este software tendrás todo lo necesario 
para crear tus propios vídeos en formato DivX, 


HE DVD Copy Plus 

Todo lo que necesitas para copiar tus pelícu- 

las de DVD a CD. 

El SoftReel MPEG-2 Video 
Decoder 1.10 

Excelente filtro de decodificación para 

Microsoft DirectShow (ActiveMovie). 


» EXTRAS 

En este apartado encontrarás todos los 
ejemplos de los que hablamos en el colec- 
cionable, para que no pierdas detalle. 
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